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Introduction aux Bases de Donnees 
Obj et-Relationnelles 



Relationnel vs. Objet-relationnel 



Exemple: II s'agit de modeliser les differentes configurations d'un reseau local ainsi que 
les affectations de machines aux utilisateurs. 

Nous faisons les hypotheses suivantes: 

Afin que deux machines situees sur deux segments differents puissent communiquer, 
elles doivent passer par une passerelle, ce qui est modelise par l'association « est relie/ 
relie » de type 1-N. La classe Interface represents la carte reseau a laquelle est connecte 
le segment; 

Sur une machine peuvent etre installes plusieurs logiciels. Dans le cas de terminaux, il 
n'y a aucun logiciel! D'autre part, un logiciel peut etre installe sur plusieurs machines. 
II s'agit done bien d'une association N-N; 

Dans cette exemple, on va supposer qu'une personne possede sa propre machine et 
qu'elle ne peut acceder a aucune autre. II s'agit ici d'une association 1-1. 
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Relationnel vs. Objet-relationnel 



Pour permettre une migration graduelle du modele relationnel vers le modele 
objet-relationnel pour les systemes existants, la norme prevoit que ce dernier 
assure une comptabilite ascendante totale avec le precedent. 

•~ Toutes les possibilites du modele relationnel sont aussi utilisables dans le 
modele objet-relationnel. 



Comment il est possible de representer les associations 
dans le modele objet-relationnel? 
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Relationnel vs. Objet-relationnel 

Association 1-1 

=> l'association entre les postes de travail ainsi de leurs utilisateurs. 



Solution avec le modele relationnel 
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Solution avec le modele objet-relationnel 
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Remplacer la cle etrangere par un pointeur (la reference de 1 
tuple concerne (acces direct au tuple associe). 



objet) directement sur le 
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Association 1-n (suite) 

=> l'association entre les tables segment et poste 
Solutions avec le modele objet-relationnel 
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Utilisation d'une seule table(imbrication totale) 

+ Recherches plus rapides (une seule table pas de jointure); 

+ Gain de place; 

+ Bien adapte pour les associations 1 a N dans lesquelles les objets fils n'ont pas 
d'existance propre. 

- On ne peut pas ajouter de fils sans que ceux-ci ne soient rattaches a un pere; 

- L' evolution de la base est plus difficile et mime parfois compromise. 
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Relationnel vs. Objet-relationnel 



Association 1-n 

=> l'association entre les tables segment et poste 
Solution avec le modele relationnel 
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Solutions avec le modele objet-relationnel 
1) 
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Solution classique: utilisation de deux tables dont l'une contient une table imbriquee. 
Chaque tuple de la table imbriquee fait reference a un tuple de l'autre table. 
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Association n-n 

=> Les installations des logiciels 

Solution avec le modele relationnel 



code 


nom 


version 


datcichat 


licence 


Logl 


word 


97 


15/03/98 


12345420 


Log2 


oracle 


8.0.3 


21/10/99 


3364485 


log3 


oracle 


8.1.5 


07/09/99 


11456723 


Log4 


excel 


97 


15/03/98 


42378104 


log5 


winNT 


4,0 


05/02/96 


74541234 


log6 


windows 


95 


19/a2/95 


96452370 


Log7 


Sybase 


11 


13/05/79 


78456145 


lo E 8 


oracle 


7.1.2 


13/05/95 


11135756 



code 


nserie 


dateinsl 


logl 


114 


16/03/98 


log3 


573 


07/09/99 


log4 


254 


10/03/98 


log6 


254 


22/02/95 


logS 


347 


15/05/95 


!og3 


347 


07/09/99 


log4 


114 


16/03/98 


logl 


573 


16/03/98 


log7 


114 


20/05/97 



nom 


hostid 


ttserie 


typeOS 


typemachine 


sophocle 


60 


254 


NT 


PC 


pericles 


61 


114 


95 


PC 


arisiophane 


62 


347 


linux 


PC 


bakounine 


63 


573 


NT 


PC 


1450 


127 


336 




terminal 



O.Lamouchi 



Relationnel vs. Objet-relationnel 



Association n-n (la suite) 
=> Les installations des logiciels 

Solutions avec le modele objet-relationnel it 
1) 

Utilisation de 3 tables (2+1) dont Tune contient ou pas une ou plusieurs tables 
imbriquees. 



On peut definir des privileges sur les attributs de l'association. 

(par exemple ici on a definie code comme privilegie) 

Lors de la selection d'un tuple on aura: 

d'abord acces a une des cles etrangeres (la plus privilegiee) 
ensuite a la suivante en accedant a la table imbriquee 
et ainsi de suite... 
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Relationnel vs. Objet-relationnel 



Conclusion 

L' extension du modele objet-relationnel est impressionnante. 

Le modele objet-relationnel ne possede pas de bases theoriques comme en possede 
le modele relationnel. La modelisation n 'est done pas aussi bien maitrisee. 



Le concepteur a la possibility de choisir parmi differentes options et cela selon 
ses gouts. 

La responsabilite revient au concepteur de ne choisir que ce qui est bon dans 
I 'approche objet en laissant de cote ce qui pourrait rendre la base incoherente. 
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Relationnel vs. Objet-relationnel 

Association n-n (la suite) 

=> Les installations des logiciels 

Solutions avec le modele objet-relationnel 

2) t 

Utilisation de 2 tables dont l'une contient une ou des tables imbriquees. 

Definir une table imbriquee contenant les attributs de la table materialisant 
l'association moins l'identifiant de la table mere. 
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